<template>
<div class="bargain-task">
    <!--搜索表单-->
    <div class="common-seach-wrap">
      <el-form
        size="small"
        :inline="true"
        :model="searchForm"
        class="demo-form-inline"
        style="float: right"
      >
        <el-form-item label=""
          ><el-input
            v-model="searchForm.search"
            :placeholder="$t('plus.input_product_or_user')"
          ></el-input
        ></el-form-item>
        <el-form-item
          ><el-button type="primary" icon="Search" @click="onSubmit"
            >{{$t('plus.search')}}</el-button
          ></el-form-item
        >
      </el-form>
    </div>

    <div class="product-content">
      <div class="table-wrap">
        <el-table
          size="small"
          :data="tableData"
          border
          style="width: 100%"
          v-loading="loading"
        >
          <el-table-column prop="productName" :label="$t('plus.product_name')" width="200">
            <template #default="scope">
              <div class="d-s-c">
                <img class="product-pic" :src="scope.row.filePath" />
                <div class="text-ellipsis">{{scope.row.productName}}</div>
              </div>
            </template>
          </el-table-column>
          <el-table-column prop="nickName" :label="$t('plus.user_info')" width="200">
            <template #default="scope">
              <div class="user-info d-s-c">
                <img :src="scope.row.avatarUrl" />
                <div class="ml10">
                  <span>{{scope.row.nickName}}</span>
                  <span class="gray">ID:{{scope.row.userId}}</span>
                </div>
              </div>
            </template>
          </el-table-column>
          <el-table-column prop="bargainPrice" :label="$t('plus.bargain_floor_price')">
            <template #default="scope">
              <div class="red fb">{{scope.row.bargainPrice}}</div>
            </template>
          </el-table-column>
          <el-table-column prop="cutMoney" :label="$t('plus.bargain_cut_amount')">
            <template #default="scope">
              <div class="orange">{{scope.row.cutMoney}}</div>
            </template>
          </el-table-column>
          <el-table-column prop="isBuy" :label="$t('plus.is_purchased')">
            <template #default="scope">
              <span v-if="scope.row.isBuy == 0" class="gray">{{$t('plus.not_purchased')}}</span>
              <span v-if="scope.row.isBuy == 1" class="green">{{$t('plus.purchased')}}</span>
            </template>
          </el-table-column>
          <el-table-column prop="status" :label="$t('plus.bargain_status')">
            <template #default="scope">
              <span v-if="scope.row.status == 0" class="gray3">{{$t('plus.in_progress')}}</span>
              <span v-if="scope.row.status == 1" class="green">{{$t('plus.bargain_success')}}</span>
              <span v-if="scope.row.status == 2" class="gray">{{$t('plus.bargain_failed')}}</span>
            </template>
          </el-table-column>
          <el-table-column
            prop="endTime"
            :label="$t('plus.bargain_end_time')"
            width="140"
          ></el-table-column>
          <el-table-column
            prop="createTime"
            :label="$t('plus.created_at')"
            width="140"
          ></el-table-column>
          <el-table-column fixed="right" :label="$t('plus.action')" width="75">
            <template #default="scope">
              <el-button @click="detailFunc(scope.row)" type="text" size="small"
                >{{$t('plus.bargain_detail')}}</el-button
              >
            </template>
          </el-table-column>
        </el-table>
      </div>

      <!--分页-->
      <div class="pagination">
        <el-pagination
          @size-change="handleSizeChange"
          @current-change="handleCurrentChange"
          background
          :current-page="curPage"
          :page-sizes="[2, 10, 20, 50, 100]"
          :page-size="pageSize"
          layout="total, sizes, prev, pager, next, jumper"
          :total="totalDataNumber"
        ></el-pagination>
      </div>
    </div>

    <!--砍价详情-->
    <Detail
      :is_detail="is_detail"
      :curModel="curModel"
      @close="closeFunc"
    ></Detail>
  </div>
</template>

<script>
import BargainApi from "@/api/bargain.js";
import Detail from "./dialog/detail.vue";
export default {
  components: {
    Detail
  },
  data() {
    return {
      /*搜索表单*/
      searchForm: {},
      /*表格数据*/
      tableData: [],
      /*一页多少条*/
      pageSize: 10,
      /*一共多少条数据*/
      totalDataNumber: 0,
      /*当前是第几页*/
      curPage: 1,
      /*是否加载完成*/
      loading: true,
      /*当前砍价*/
      curModel: {},
      /*是否显示详情*/
      is_detail: false
    };
  },
  created() {
    /*获取列表*/
    this.getData();
  },
  methods: {
    /*搜索*/
    onSubmit() {
      this.curPage = 1;
      this.getData();
    },
    /*获取列表*/
    getData() {
      let self = this;
      let Params = self.searchForm;
      Params.pageIndex = self.curPage;
      Params.pageSize = self.pageSize;
      self.loading = true;
      BargainApi.taskList(Params, true).then(res => {
        self.loading = false;
        self.tableData = res.data.records;
        self.totalDataNumber = res.data.total;
      }).catch(error => {});
    },
    /*选择第几页*/
    handleCurrentChange(val) {
      this.curPage = val;
      this.getData();
    },
    /*每页多少条*/
    handleSizeChange(val) {
      this.curPage = 1;
      this.pageSize = val;
      this.getData();
    },
    /*查看砍价详情*/
    detailFunc(e) {
      this.curModel = e;
      this.is_detail = true;
    },
    /*关闭砍价详情*/
    closeFunc() {
      this.curModel = {};
      this.is_detail = false;
    }
  }
};
</script>

<style>
.bargain-task .user-info img {
  width: 30px;
  height: 30px;
  border-radius: 50%;
}
.bargain-task .product-pic {
  width: 30px;
  height: 30px;
}
</style>

